Claim Listing 



1 . (previously presented) A coordinated pusli synclironization method, 
comprising tlie acts of: 

detecting clianges to a local application data store; 

identifying a record affected by a detected change; 

pushing the identified record to a remote application data store; 

ascertaining whether the pushed record, in its current form as affected by the 
detected change, has already been replicated or deleted in the remote application 
data store in order to determine whether the remote application data store will be 
updated with the pushed record; 

if not, updating the remote application data store with the pushed record and 
identifying the pushed record in the remote application data store as having been 
pushed from the local application data store to the remote application data store, 
othenwise ignoring the pushed record. 

2. (previously presented) The method of Claim 1 , wherein the act of 
ascertaining includes comparing a local change counter associated with the pushed 
record in the local application data store with a remote change counter associated 
with a corresponding record in the remote application data store. 

3. (original) The method of Claim 1 , wherein the act of pushing the identified 
record comprises: 

if the identified record has been detected as being new, pushing a replica of 
the identified record with instructions to save the replica in the remote application 
data store; 

if the identified record has been detected as being modified, pushing a replica 
of the identified record with instructions to save the replica in the remote application 
data store replacing a prior version of the record; and 
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if the identified record lias been detected as being deleted, pusliing 
instructions to delete a prior version of the identified contained in the remote 
application data store. 

4. (previously presented) The method of Claim 1 , wherein the act of 
identifying the pushed record in the remote application data store as a pushed record 
comprises associating an indicator with the pushed record identifying the pushed 
record in the remote application data store as a pushed record. 

5. (previously presented) A coordinated user-initiated synchronization method, 
comprising the acts of: 

detecting changes to a local application data store; 

identifying a record affected by a detected change; 

ascertaining whether the identified record, in its current form as affected by 
the detected change, was pushed to the local application data store from a remote 
application data store; and 

if not, synchronizing the remote application data store with the local 
application data store. 

6. (previously presented) The method of Claim 5, wherein the act of 
ascertaining includes examining an indicator associated with a pushed record 
identifying the pushed record in the remote application data store as a pushed 
record. 

7. (original) The method of Claim 5, wherein the act of synchronizing 
comprises: 

if the identified record has been detected as being new, replicating the 
identified record in the remote application data store; 
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if the identified record lias been detected as being modified, replicating tlie 
identified record in tlie remote application data store replacing a prior version of the 
record; and 

if the identified record has been detected as being deleted, deleting the 
version of the identified record from the remote application data store. 

8. (cancelled) 

9. (cancelled) 

1 0. (previously presented) A coordinated push and user-initiated 
synchronization method, comprising: 

detecting changes to a local application data store; 

identifying a first record in the local application data store affected by a 

detected change; 

pushing the first record to a remote application data store; 

ascertaining whether the pushed record, in its current form as affected by the 
detected change, has already been replicated in or deleted from the remote 
application data store and, if not, updating the remote application data store with the 
pushed record; 

detecting changes to the remote application data store; 

identifying a second record in the remote application data store affected by a 
detected change; 

ascertaining whether the second record, in its current form as affected by the 
detected change, has already been pushed into the remote application data store in 
order to determine whether the remote application data store will be updated with the 
pushed record and, if not, synchronizing the remote application data store with the 
local application data store, othenwise ignoring the pushed record. 
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1 1 . (previously presented) The method of Claim 1 0, wherein the act of 
ascertaining whether the pushed record has been replicated in or deleted from the 
remote application data store includes comparing a local change counter associated 
with the pushed record in the local application data store with a remote change 
counter associated with a corresponding record in the remote application data store. 

12. (previously presented) The method of Claim 10, wherein the act of 
ascertaining whether the pushed record has been replicated in or deleted from the 
remote application data store includes examining an indicator associated with the 
pushed record identifying the pushed record in the remote application data store as a 
pushed record. 

13. (cancelled) 

14. (cancelled) 

15. (currently amended) The method of Claim 10, further comprising, after 
updating the remote application data store with the pushed record, identifying the 
pushed record in the remote application data store as having been pushed from the 
local application data store to the remote application data store. 

16. (cancelled) 

1 7. (previously presented) A coordinated push synchronization computer 
program product comprising a computer useable medium having computer readable 
instructions thereon for: 

detecting changes to a local application data store; 
identifying a record affected by a detected change; 
pushing the identified record to a remote application data store; 
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ascertaining wlietlier tlie puslied record, in its current form as affected by tlie 
detected cliange, lias already been replicated or deleted in the remote application 
data store in order to determine whether the remote application data store will be 
updated with the pushed record; 

if not, updating the remote application data store with the pushed record and 
identifying the pushed record in the remote application data store as having been 
pushed from the local application data store to the remote application data store, 
othenrt/ise ignoring the pushed record. 



18. (previously presented) The product of Claim 17, wherein the instructions 
for ascertaining include instructions for comparing a local change counter associated 
with the pushed record in the local application data store with a remote change 
counter associated with a corresponding record in the remote application data store. 

19. (original) The product of Claim 17, wherein the instructions for pushing the 
identified record comprise instructions for: 

if the identified record has been detected as being new, pushing a replica of 
the identified record with instructions to save the replica in the remote application 
data store; 

if the identified record has been detected as being modified, pushing a replica 
of the identified record with instructions to save the replica in the remote application 
data store replacing a prior version of the record; and 

if the identified record has been detected as being deleted, pushing 
instructions to delete a prior version of the identified contained in the remote 
application data store. 



20. (previously presented) The product of Claim 17, wherein the instructions 
for identifying the pushed record in the remote application data store as a pushed 
record comprise instructions for associating an indicator with the pushed record 
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identifying tlie pusfied record in tlie remote application data store as a puslied 
record. 

21. (previously presented) A coordinated user-initiated synchronization 
computer program product comprising a computer useable medium having computer 
readable instructions thereon for: 

detecting changes to a local application data store; 

identifying a record affected by a detected change; 

ascertaining whether the identified record, in its current form as affected by 
the detected change, was pushed to the local application data store from a remote 
application data store; and 

if not, synchronizing the remote application data store with the local 
application data store. 

22. (previously presented) The product of Claim 21 , wherein the instructions 
for ascertaining include instructions for examining an indicator associated with a 
pushed record identifying the pushed record in the remote application data store as a 

pushed record. 

23. (original) The product of Claim 21, wherein the instructions for 
synchronizing comprise instructions for: 

if the identified record has been detected as being new, replicating the 
identified record in the remote application data store; 

if the identified record has been detected as being modified, replicating the 
identified record in the remote application data store replacing a prior version of the 
record; and 

if the identified record has been detected as being deleted, deleting the 
version of the identified record from the remote application data store. 

24. (cancelled) 
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25. (cancelled). 



26. (previously presented) A coordinated push and user-initiated 
synchronization computer program product comprising a computer useable medium 
having computer readable instructions thereon for: 

detecting changes to a local application data store; 

identifying a first record in the local application data store affected by a 
detected change; 

pushing the first record to a remote application data store; 

ascertaining whether the pushed record, in its current form as affected by the 
detected change, has already been replicated in or deleted the remote application 
data store and, if not, updating the remote application data store with the pushed 
record; 

detecting changes to the remote application data store; 
identifying a second record in the remote application data store affected by a 
detected change; 

ascertaining whether the second record, in its current form as affected by the 
detected change, has already been pushed into the remote application data store in 
order to determine whether the remote application data store will be updated with the 
pushed record and, if not, synchronizing the remote application data store with the 
local application data store, otherwise ignoring the pushed record. 

27. (previously presented) The product of Claim 26, wherein the instructions 
for ascertaining whether the pushed record has been replicated in or deleted from 
the remote application data store include instructions for comparing a local change 
counter associated with the pushed record in the local application data store with a 
remote change counter associated with a corresponding record in the remote 
application data store. 
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28. (previously presented) The product of Claim 26, wherein the instructions 
for ascertaining whether the pushed record has been replicated in or deleted from 
the remote application data store include instructions for examining an indicator 
associated with the pushed record identifying the pushed record in the remote 
application data store as a pushed record. 

29. (cancelled) 

30. (cancelled) 

31 . (previously presented) The product of Claim 26, further comprising 
instructions for, after updating the remote application data store with the pushed 
record, identifying the pushed record in the remote application data store as having 
been pushed from the local application data store to the remote application data 
store. 

32. (cancelled) 

33. (cancelled) 

34. (cancelled) 

35. (cancelled) 

36. (cancelled) 

37. (cancelled) 

38. (cancelled) 
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39. (cancelled) 



40. (cancelled) 



41. (cancelled) 



42. (cancelled) 



43. (cancelled) 



44. (cancelled) 



45. (cancelled) 



46. (cancelled) 



47. (previously presented) The method of Clainn 4, wherein the act of 
associating comprises setting a coordination flag for the pushed record. 

48. (previously presented) The method of Claim 6, wherein the indicator 
comprises a coordination flag, a set coordination flag indicating that a record is a 
pushed record and a reset coordination flag indicating that the record is not a pushed 
record. 
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